# AP16026

# C16x

Software Emulation of the I<sup>2</sup>C-bus using the High-Speed Synchronous Serial Interface

Microcontrollers



#### C16x

| Revisio                                           | n History:                                                           | 2004-02    | V 1.0 |
|---------------------------------------------------|----------------------------------------------------------------------|------------|-------|
| Previous Version: -                               |                                                                      |            |       |
| Page Subjects (major changes since last revision) |                                                                      |            |       |
| All                                               | Updated Layout to Infineon Corporate Design, updated release to 1.0, |            |       |
| Content unchanged!                                |                                                                      | inchanged! |       |
|                                                   |                                                                      |            |       |
|                                                   |                                                                      |            |       |
| -                                                 |                                                                      |            |       |
|                                                   |                                                                      |            |       |
|                                                   |                                                                      |            |       |

Controller Area Network (CAN): License of Robert Bosch GmbH

#### We Listen to Your Comments

Any information within this document that you feel is wrong, unclear or missing at all? Your feedback will help us to continuously improve the quality of this document. Please send your proposal (including a reference to this document) to:

mcdocu.comments@infineon.com

Edition 2004-02
Published by
Infineon Technologies AG
81726 München, Germany
© Infineon Technologies AG 2006.
All Rights Reserved.

#### **LEGAL DISCLAIMER**

THE INFORMATION GIVEN IN THIS APPLICATION NOTE IS GIVEN AS A HINT FOR THE IMPLEMENTATION OF THE INFINEON TECHNOLOGIES COMPONENT ONLY AND SHALL NOT BE REGARDED AS ANY DESCRIPTION OR WARRANTY OF A CERTAIN FUNCTIONALITY, CONDITION OR QUALITY OF THE INFINEON TECHNOLOGIES COMPONENT. THE RECIPIENT OF THIS APPLICATION NOTE MUST VERIFY ANY FUNCTION DESCRIBED HEREIN IN THE REAL APPLICATION. INFINEON TECHNOLOGIES HEREBY DISCLAIMS ANY AND ALL WARRANTIES AND LIABILITIES OF ANY KIND (INCLUDING WITHOUT LIMITATION WARRANTIES OF NON-INFRINGEMENT OF INTELLECTUAL PROPERTY RIGHTS OF ANY THIRD PARTY) WITH RESPECT TO ANY AND ALL INFORMATION GIVEN IN THIS APPLICATION NOTE.

#### Information

For further information on technology, delivery terms and conditions and prices please contact your nearest Infineon Technologies Office (www.infineon.com).

#### Warnings

Due to technical requirements components may contain dangerous substances. For information on the types in question please contact your nearest Infineon Technologies Office.

Infineon Technologies Components may only be used in life-support devices or systems with the express written approval of Infineon Technologies, if a failure of such components can reasonably be expected to cause the failure of that life-support device or system, or to affect the safety or effectiveness of that device or system. Life support devices or systems are intended to be implanted in the human body, or to support and/or maintain and sustain and/or protect human life. If they fail, it is reasonable to assume that the health of the user or other persons may be endangered.



# **Table of Contents**

| Table of | Contents                                  | Page |
|----------|-------------------------------------------|------|
| 1        | Introduction to I <sup>2</sup> C-bus      | 2    |
| 2        | I <sup>2</sup> C-bus Specifications       | 2    |
| 2.1      | Data Transfer formats                     |      |
| 2.2      | Timing Diagram                            | 2    |
| 2.3      | Hardware Connection                       | 2    |
| 3        | Software Description                      | 2    |
| 3.1      | Software Concept                          | 2    |
| 3.2      | Description of Module Subroutines         |      |
| 3.2.1    | I <sup>2</sup> C-BUS Software Module      | 2    |
| 3.2.2    | I <sup>2</sup> C-BUS Application Software | 2    |
| 3.3      | Software Compilation                      | 2    |



Introduction to I<sup>2</sup>C-bus

# 1 Introduction to I<sup>2</sup>C-bus

The I<sup>2</sup>C-bus or Inter-Integrated Circuit bus has been developed by Philips. It allows integrated circuits to communicate directly with each other via a simple bi-directional 2-wire bus. The two bus lines are serial clock line (SCL), and serial data line (SDA). Nowadays, the I<sup>2</sup>C-bus becomes a standard bus system which is used in consumer electronics, telecommunications, and industrial electronics. This software module of I<sup>2</sup>C-bus emulation supports the single master protocol only. It is using the High-Speed Synchronous Serial Interface to generate clock, and transmit or receive the data. The clock frequency of the I<sup>2</sup>C-bus can achieve up to 100 KHz with 20 MHz CPU of the C16x microcontroller.



I<sup>2</sup>C-bus Specifications

# 2 I<sup>2</sup>C-bus Specifications

#### 2.1 Data Transfer formats

A HIGH-to-LOW transition of the data line (SDA) while the clock line (SCL) is HIGH indicates a START condition. A LOW-to-HIGH transition of the SDA while SCL is HIGH defines a STOP condition. The data line can only be changed when the clock signal on the SCL line is LOW. Therefore, the data on the SDA line must be stable during the HIGH period of the clock signal. The bus is considered to be busy after the Start condition and is considered to be free at a certain time interval after the STOP condition.

Each information puts on the SDA line must be 8-bit long. The data is transferred serially with the most significant bit first, and followed by an acknowledge bit. The 9th clock pulse of the acknowledge bit is generated by the master. The transmitting device has to release the SDA line (HIGH or in the high impedance state) during this clock pulse while the device that needs to acknowledge has to pull down the SDA line during this clock pulse. The number of data bytes transferred between the START and STOP condition from the transmitter and receiver is not limited.

The receiver is obliged to generate an acknowledge bit after each byte of data that has been received. When the receiver does not provide an acknowledge bit after having received a byte of data, the data line must be left HIGH or in the high impedance state by the slave. The master can then generate a STOP condition to abort the transfer. One of the reasons for the receiver not providing the acknowledge bit is that the receiver is performing some real-time function. If the master is receiving data, it must signal the end of the data to the slave by not generating an acknowledge bit on the last byte of data received. Then, the slave must release the data line to allow the master to generate the STOP condition.

A complete data transfer format is shown in Figure 1. After a START condition, a slave address is sent. The address is 7 bits long followed by an 8th bit which is a data direction bit (R/W). A "0" for data direction bit indicates a transmission (WRITE), and a "1" indicates a request for data (READ). Figure 2 shows the I<sup>2</sup>C-bus data transfer format of writing data from master to slave device. Figure 3 shows the data transfer format of reading data from the slave device.

A data transfer is always terminated by STOP condition generated by the master. However, if the master still wishes to communicate on the bus, it can generate a repeated START condition and address the same device or another slave device without first generating a STOP condition. This combined data transfer format is shown in figure 4.

# I<sup>2</sup>C-bus Specifications



Figure 1 A complete data transfer format of I<sup>2</sup>C-bus



Figure 2 I<sup>2</sup>C-bus data transfer format of writing data to slave



# I<sup>2</sup>C-bus Specifications



Figure 3 I<sup>2</sup>C-bus data transfer format of reading data from slave



Figure 4 A combined data transfer format for I<sup>2</sup>C-bus

Application Note 7 V 1.0, 2004-02



I<sup>2</sup>C-bus Specifications

## 2.2 Timing Diagram

The clock frequency of SCL is in the range of 0 up to 100 KHz. The clock on the  $I^2$ C-bus has a minimum LOW period of 4.7  $\mu$ s , and a minimum HIGH period of 4.0  $\mu$ s.

Occasionally, the slave device may slow down the transmission by holding the clock line low after receiving a byte of data from microcontroller. This event is defined as a WAIT condition. Therefore, the master needs to switch the SCL output to high impedance and read the SCL line before transmitting another byte of data to the slave device.

Figure 5 shows the data transfer timing requirements in detail. The description of the abbreviations used is shown in the Table 1. The minimum timing requirements are needed to be fulfilled in order for I<sup>2</sup>C-bus to operate properly.



Figure 5 I<sup>2</sup>C-bus timing diagram

# I<sup>2</sup>C-bus Specifications

Table 1 Abbreviation for I<sup>2</sup>C-bus timing diagram

| Parameter                                                                          | Symbol              | Limit Values |      | Unit |
|------------------------------------------------------------------------------------|---------------------|--------------|------|------|
|                                                                                    |                     | min.         | max. |      |
| Bus free time between a STOP and START condition                                   | t <sub>BUF</sub>    | 4.7          |      | μs   |
| 2. Hold time for START condition. After this period, the first pulse is generated. | t <sub>hd;sta</sub> | 4.0          |      | μs   |
| 3. The HIGH period of SCL clock.                                                   | t <sub>HIGH</sub>   | 4.0          |      | μs   |
| 4. The LOW period of SCL clock.                                                    | t <sub>LOW</sub>    | 4.7          |      | μs   |
| 5. Data hold time                                                                  | t <sub>hd;dat</sub> | 0*           |      | μs   |
| 6. Rise time for both SCL and SDA signals.                                         | t <sub>R</sub>      |              | 1.0  | μs   |
| 7. Fall time for both SCL and SDA signals.                                         | t <sub>F</sub>      |              | 300  | ns   |
| 8. Data set-up time                                                                | t <sub>su;dat</sub> | 250          |      | ns   |
| 9. Set-up time for a repeated START condition.                                     | t <sub>su;sta</sub> | 4.7          |      | μs   |
| 10. Set-up time for STOP condition.                                                | t <sub>su:sto</sub> | 4.0          |      | μs   |
| 11. SCL clcok frequency                                                            | f <sub>scl</sub>    | 0            | 100  | KHz  |
| 12. Capacitor load for each bus line                                               | C <sub>b</sub>      |              | 400  | pF   |

<sup>\*</sup> A device must internally provide a hold time of at least 300 ns for SDA signal in order to bridge the undefined region of the falling edge of SCL.



I<sup>2</sup>C-bus Specifications

#### 2.3 Hardware Connection

Every device connected to the I²C-bus must have an open drain/open collector output for both the clock (SCL) and data (SDA) lines. Each of the lines is connected to the VDD supply via a common pull-up resistor of 10 K $\Omega$  in value. The connection among master and many slave devices is shown in figure 6. The number of devices that can be connected to the I²C-bus is limited only by the maximum bus load capacitance of 400 pF.



Figure 6 Hardware connection among master and slave devices

**Software Description** 

# 3 Software Description

## 3.1 Software Concept

The clock and data of the I<sup>2</sup>C-bus are generated by the High-Speed Synchronous Serial Interface of the C16x microcontroller. The clock frequency of the I<sup>2</sup>C-bus is 100 KHz with 20 MHz CPU of the microcontroller. The baud rate generator for the SCL line can be determined by the following formula:

$$B_{SSC} = \frac{f_{CPU}}{2 * ( + 1)}$$

$$SSCBR = (\frac{f_{CPU}}{2 * Baudrate_{SSC}}) - 1$$

<SSCBR> represents the content of the reload register.

For example, SSCBR = (20 MHz/(2\*100 KHz)) -1 = 99 or 63H. In order to achieve 100 KHz of SCL clock frequency, SSCBR must be assigned as 63H which is based on 20 MHz CPU clock of the 16x microcontroller.

The HS-SSC uses 3 I/O lines for communication; P3.13 (SCLK) serves as the clock line, P3.8 (MRST) serves as the serial data input line (master receive/slave transmit), and P3.9 (MTSR) serves as the serial data output (master transmit/slave receive). The P3.8 and P3.9 pins are connected together as the SDA line for half duplex operation.

The operating mode of the SSC is controlled by the control register SSCCON which has been configured as the 8 bit data with MSB first, in master mode, shift transmit data on the leading clock edge, latch on trailing edge, idle clock line is low, and leading clock edge is low-to-high transition.

This software module does not check the clock line before a byte of data is sent or received. This is because the clock line is controlled by the hardware peripheral of SSC. In other words, the WAIT condition will not be detected before a byte of data is sent or received. Therefore, it is compulsory to check the acknowledge bit. If the acknowledge bit is not received from the slave device, the data is needed to transmit again. The WAIT condition can only be checked before START and after STOP condition in this case.

The I2C\_SW.C software module is divided into 5 software subroutines which can be accessed by the main or external program. Those 5 software subroutines are used to construct the data transfer format of the I<sup>2</sup>C-bus. Those 5 software subroutines are I2cInit, I2cStart, I2cMasterWrite, I2cMasterRead, and I2cStop.



## **Software Description**

The two types of data transfer format (master write, and master read/combined format) are written in the HSSCTEST.C. The HSSCTEST.C is a simple test program which just to verify the I2C\_HSSC.C software module. This test program is to transmit 10 bytes of data to E²PROM IC from the array location of the microcontroller. The 10 bytes of data will be stored in the word address 0 to 9 of the E²PROM IC. Next, the microcontroller will read back the contents of the 10 bytes from the word address 0 to 9 of the E²PROM IC and then store it into another array location of the microcontroller.

# 3.2 Description of Module Subroutines

#### 3.2.1 I<sup>2</sup>C-BUS Software Module

| Source file: | I2C_HSSC.C |
|--------------|------------|
| Header file: |            |

## Description

This module is a standard I<sup>2</sup>C-bus single master protocol by using High-Speed Synchronous Serial Interface of the C16x microcontroller. The clock and as well as transmit/receive data are handled by the hardware peripheral of HS-SSC.

#### **Module Subroutines**

- 1. void Delay(unsigned int count);
- 2. unsigned char Check SCL();
- unsigned char I2cInit();
- 4. void I2cStart();
- 5. unsigned char I2cMasterWrite(unsigned char input byte);
- 6. unsigned char I2cMasterRead(unsigned char ack);
- 7. unsigned char I2cStop();

## void Delay(unsigned int count)

To generate START and STOP condition, and 9th clock pulse.

## Table 2 Delay - Parameter

| Parameter          | Description                     |  |
|--------------------|---------------------------------|--|
| unsigned int count | number of count for time delay. |  |

Application Note 12 V 1.0, 2004-02



## **Software Description**

## unsigned char Check\_SCL()

Send HIGH and read the SCL line. It will wait until the line has been released from slave device with the time-out of 10 ms.

#### Table 3 Check SCL - Parameter

| Parameter | Description |
|-----------|-------------|
| None      |             |
|           |             |

#### Return

The return value is "0" if the clock and data lines have no problem. Otherwise, the return value will be "1".

## unsigned char I2cInit()

Initialize the I<sup>2</sup>C-bus. P3.8 = MRST, P3.9 = MTSR, P3.13 = SCL. The MRST and MTSR are connected together for I<sup>2</sup>C operation. Configure the High-Speed Synchronous Serial interface to generate 100 Kbaud clock frequency and set the control register to produce a 8 bit data with MSB first, in master mode, shift transmit data on the leading clock edge, latch on trailing edge, idle clock line is low, and leading clock edge is low-to-high transition. It also check the clock and data lines for any bus faulty like no pull-up resistor on SDA/SCL or pull-down to low by the slave device.

#### Table 4 | I2cInit - Parameter

| Parameter | Description |
|-----------|-------------|
| None      |             |
| Detum     |             |

#### Return

The return value is "0" if the clock and data lines have no problem. Otherwise, the return value will be "1".

## void I2cStart()

Generate a START condition on I2C-bus.

#### Table 5 | I2cStart - Parameter

| Parameter | Description |
|-----------|-------------|
| None      |             |

Application Note 13 V 1.0, 2004-02



## **Software Description**

## unsigned char I2cMasterWrite(unsigned char input\_byte)

Output one byte of data to the slave device.

#### Table 6 I2cMasterWrite - Parameter

| Parameter                | Description                                  |
|--------------------------|----------------------------------------------|
| unsigned char input_byte | one byte of data to be sent to slave device. |

#### Return

If the return value is "0", writing one byte of data to slave device is successfully. Otherwise, one byte of data is needed to be sent again because there is no acknowledge from the slave device.

## unsigned char I2cMasterRead(unsigned char ack)

Read one byte of data from the slave device.

Table 7 I2cMasterRead - Parameter

| Parameter         | Description                                                                                                                                          |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| unsigned char ack | "0" - generate LOW output by the master after a byte of data is received. "1" - generate HIGH output by the master after a byte of data is received. |

#### Return

If the return value is "0", reading one byte of data from slave device is successfully. Otherwise, one byte of data is needed to be received again because there is no acknowledge from the slave device.



## **Software Description**

#### unsigned char I2cStop()

Generate a STOP condition on the I<sup>2</sup>C-bus. In addition, it will generate clock pulses until the line is released by the slave device and the time-out is 10 ms before returning a "HIGH" value indicating an error.

Table 8 I2cStop - Parameter

| Parameter | Description |
|-----------|-------------|
| None      |             |
| Return    |             |

The return value is "0" if the clock and data lines have no problem. Otherwise, the return value will be "1".

# 3.2.2 I<sup>2</sup>C-BUS Application Software

| Source file: | HSSCTEST.C |
|--------------|------------|
| Header file: | I2C_HSSC.H |

## Description

This program is just for testing only. The purpose of this program is to make use of the standard I<sup>2</sup>C protocol module (I2C\_HSSC.C) to control the nonvolatile memory (E<sup>2</sup>PROM). This program writes 10 bytes of data into E<sup>2</sup>PROM in sequence and the data is retrieved from the array location of microcontroller. Then read back 10 bytes of data from the E<sup>2</sup>PROM at the same location to which they have been programmed and store them in the array location of microcontroller.

#### Software subroutines

- unsigned char CheckWrite();
- unsigned char WriteE2prom(unsigned char address, signed int sub\_addr,unsigned char \*buffer,unsigned char count);
- unsigned char ReadE2prom (unsigned char address,signed int sub\_addr,unsigned char \*buffer,unsigned char count);



## **Software Description**

## unsigned char CheckWrite()

Check for the completion of programming after the memory write. If the programming is completed, the acknowledge bit will be "0".

Table 9 CheckWrite - Parameter

| Parameter | Description |
|-----------|-------------|
| None      |             |
| Return    | <u>.</u>    |

If the return value is "0", the programming of E<sup>2</sup>PROM is consider done. Otherwise, the programming of E<sup>2</sup>PROM is still in progress.

## unsigned char WriteE2prom(unsigned char adress, signed int sub addr,unsigned char \*buffer,unsigned char count)

Write number of data bytes to E<sup>2</sup>PROM. The flow of this subroutine is derived from the data format of writing to the E2PROM as in the figure 2.

Table 10 WriteE2prom - Parameter

| Parameter             | Description                              |
|-----------------------|------------------------------------------|
| unsigned char address | specifies the slave device address       |
| signed int sub_addr   | specifies the sub-address/word address   |
| unsigned char *buffer | point to the location of data to be sent |
| unsigned char count   | number of bytes to be sent               |
| Return                |                                          |

#### Return

If the return value is "0", the programming of E2PROM is completed. Otherwise, the data is needed to be sent again because there is no acknowledge from slave device.



**Software Description** 

# unsigned char ReadE2prom(unsigned char address, signed int sub\_addr,unsigned char \*buffer,unsigned char count)

Read number of data bytes from E<sup>2</sup>PROM. The flow of this subroutine is derived from the data format of reading from the E<sup>2</sup>PROM as in the figure 3.

Table 11 ReadE2prom - Parameter

| Parameter             | Description                                |
|-----------------------|--------------------------------------------|
| unsigned char address | specifies the slave device address         |
| signed int sub_addr   | specifies the sub-address                  |
| unsigned char *buffer | point to the location of data to be stored |
| unsigned char count   | number of bytes to be received             |
| Return                | ·                                          |

If the return value is "0", the reading of E²PROM is completed. Otherwise, the data is needed to be sent again because there is no acknowledge from slave device.

# 3.3 Software Compilation

The compilation of this software is using the KEIL C166 compiler. Firsts of all, under the PROJECT menu, clicks on the "New Project", then key in the name of this project and add files to the project which are the I2C\_HSSC.C and HSSCTEST.C. Then, save the project. After-that, go to the OPTIONS menu and click on the "C166 Compiler...". Lastly, select the option under OBJECT and cross the box under "Enable 80C167 instructions". This option will allow you to use the C16x derivatives. Now the project is really to compile and link all the object files. The compiling and linking of the project can be done by clicking the icon "BUILD ALL".

The AP162601.EXE is a compressed file and contains I2C\_HSSC.H, I2C\_HSSC.C, and HSSCTEST.C. All these files are necessary to complete the compilation of the software program.

http://www.infineon.com Published by Infineon Technologies AG